javascript - 将数据 URI 转换为文件
全部标签 我已经使用RoR进行开发一年多了,但我才刚刚开始使用RSpec进行测试。对于标准模型/Controller测试,我通常没有任何问题,但问题是我想测试一些复杂的功能流程,并且不知道如何构建我的测试文件夹/文件/数据库。这是我的应用程序的基本结构:classCustomerhas_one:wallethas_many:ordershas_many:invoices,through::ordershas_many:invoice_summariesendclassWalletbelongs_to:customerendclassOrderhas_one:invoicebelongs_to:c
在Java中,通常您会创建两个具有相同包层次结构的源文件夹src和test。在Ruby中,您是否只是将所有测试放在与被测类相同的文件夹中?还是在单独的文件夹中创建类似的层次结构?如果是这样,您如何管理单元测试中的require路径? 最佳答案 起初,每个gem都有一个典型的布局。代码几乎完全在lib中。在根目录中,只有README、gemspec文件和一些可选配置数据等元数据。如果您使用Rails或Sinatra之类的工具编写Web应用程序,则会改用它们的布局标准。尽管在所有这些项目类型中,都可以在相似的位置找到测试。根据您使用的测
pg-ruby允许您一次性向数据库发送多个查询,这有助于最大限度地减少访问数据库的次数:results=[]conn.send_query('QUERY1;QUERY2;QUERY3')conn.blockwhileresult=conn.get_resultresults假设对于任何result我已经知道ActiveRecord模型,将结果转换为模型的合适方法是什么?现在我正在做以下事情:fields=result.fieldsmodels=result.values.map{|value_set|Model.new(Hash[fields.zip(value_set)])}该方法的
在使用File.new(big_file)打开一个文件(不关闭它)1016次(Ubuntu)或1017次(CentOS)后,似乎有一个限制并引发:Toomanyopenfiles@rb_sysopen-big_file(Errno::EMFILE)有什么办法可以提高这个限制吗?在我的系统上,ulimit设置为unlimited。 最佳答案 EMFILE是在您的进程中打开的文件太多。ENFILE是整个系统打开的文件太多。所以Errno::EMFILE是因为ruby进程打开了太多文件。此限制可能设置为默认1024可以看到:$ulim
我正在使用seeds.rb填充一些状态模型引用数据:State.create:name=>'Alabama',:abbreviation=>'AL'State.create:name=>'Alaska',:abbreviation=>'AK'#...虽然我没有使用状态固定装置(因为它是种子数据,我认为纯粹为了测试而复制它不会是DRY),Rails测试框架似乎删除了所有状态种子数据测试。(我正在删除、重新创建、迁移和重新播种测试数据库,并在单元测试运行之前确认数据在那里。)结果是此断言在seeds.rb中成功但在单行测试中失败:assert_equal51,State.all.size1
我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a
这是有效的,但它是在黑暗中刺伤。我对Ruby知之甚少。为给定资源提供普通旧文件的公认方式是什么?get'/xyz'doFile.read'abc.html'end 最佳答案 您可以使用set:public来指定静态文件的目录。然后,您可以使用send_file()提供文件,例如:get'/static_file'dosend_file('my_static_file')end 关于ruby-Sinatra:提供普通旧文件的正确方法是什么?,我们在StackOverflow上找到一个类似的
我有一个数组,其中包含X个值。下面的数组只有4个,但我需要代码是动态的,而不是依赖于只有四个数组对象。array=["成人","家庭","单例","child"]我想将array转换为如下所示的散列:hash={0=>'成人',1=>'家庭',2=>'单例',3=>'child'散列应具有与数组中对象一样多的键/值对,值应从0开始,每个对象递增1。 最佳答案 使用Enumerable#each_with_index:Hash[array.each_with_index.map{|value,index|[index,value]}]
我一直在为Rails应用开发日志查看器,发现我需要从下到上阅读大约200行的日志文件,而不是默认的从上到下阅读。日志文件可能会变得非常大,所以我已经尝试并排除了IO.readlines("log_file.log")[-200..-1]方法。有没有其他方法可以在不需要插件或gem的情况下在Ruby中反向读取文件? 最佳答案 执行此操作且适用于大型文件的唯一正确方法是从末尾一次读取n个字节,直到获得所需的行数。这基本上就是Unixtail的工作方式。IO#tail(n)的示例实现,它将最后的n行作为Array返回:classIOTAI
我知道ActiveSupport提供了此功能。h=ActiveSupport::OrderedOptions.newh.boy='John'h.girl='Mary'h.boy#=>'John'h.girl#=>'Mary'但是我已经有一个很大的散列,我想使用点表示法访问该散列。这是我尝试过的:large_hash={boy:'John',girl:'Mary'}h=ActiveSupport::OrderedOptions.new(large_hash)h.boy#=>nil那没有用。我怎样才能使这项工作。我正在使用ruby1.9.2更新:抱歉,我应该提到我不能使用openstruc